package com.zj.leetcode.medium;

/**
 * @program: algorithm
 * @description: 压缩字符串
 * 443 string-compression
 * //给你一个字符数组 chars ，请使用下述算法压缩：
 * //
 * // 从一个空字符串 s 开始。对于 chars 中的每组 连续重复字符 ：
 * //
 * //
 * // 如果这一组长度为 1 ，则将字符追加到 s 中。
 * // 否则，需要向 s 追加字符，后跟这一组的长度。
 * //
 * //
 * // 压缩后得到的字符串 s 不应该直接返回 ，需要转储到字符数组 chars 中。需要注意的是，如果组长度为 10 或 10 以上，则在 chars 数组中会
 * //被拆分为多个字符。
 * //
 * // 请在 修改完输入数组后 ，返回该数组的新长度。
 * //
 * // 你必须设计并实现一个只使用常量额外空间的算法来解决此问题。
 * //
 * //
 * //
 * // 示例 1：
 * //
 * //
 * //输入：chars = ["a","a","b","b","c","c","c"]
 * //输出：返回 6 ，输入数组的前 6 个字符应该是：["a","2","b","2","c","3"]
 * //解释：
 * //"aa" 被 "a2" 替代。"bb" 被 "b2" 替代。"ccc" 被 "c3" 替代。
 * //
 * //
 * // 示例 2：
 * //
 * //
 * //输入：chars = ["a"]
 * //输出：返回 1 ，输入数组的前 1 个字符应该是：["a"]
 * //解释：
 * //没有任何字符串被替代。
 * //
 * //
 * // 示例 3：
 * //
 * //
 * //输入：chars = ["a","b","b","b","b","b","b","b","b","b","b","b","b"]
 * //输出：返回 4 ，输入数组的前 4 个字符应该是：["a","b","1","2"]。
 * //解释：
 * //由于字符 "a" 不重复，所以不会被压缩。"bbbbbbbbbbbb" 被 “b12” 替代。
 * //注意每个数字在数组中都有它自己的位置。
 * //
 * //
 * //
 * //
 * // 提示：
 * //
 * //
 * // 1 <= chars.length <= 2000
 * // chars[i] 可以是小写英文字母、大写英文字母、数字或符号
 * //
 * // Related Topics 双指针 字符串
 * // 👍 282 👎 0
 * @author: Zhang Bo
 * @create: 2022-01-14 17:05
 **/
public class StringCompression {
    public static void main(String[] args) {
//        char[] chars = new char[]{'a', 'a', 'b', 'b', 'c', 'c', 'c'};
//        char[] chars = new char[]{'a', 'a', 'b'};
//        char[] chars = new char[]{'a', 'b', 'a'};
//        char[] chars = new char[]{'a', 'a', 'a'};
        char[] chars = new char[]{'a'};
        Solution solution = new StringCompression().new Solution();
        System.out.println(solution.compress(chars));
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public int compress(char[] chars) {
            StringBuilder str = new StringBuilder();

            int size = 0;
            int left = 0;
            int right = 0;

            while (right < chars.length) {
                if (chars[left] != chars[right]) {
                    if (right - left == 1) {
                        ++size;
                        str.append(chars[left]);
                    } else {
                        str.append(chars[left]);
                        size = size + this.intToSize(right - left, str) + 1;
                    }
                    left = right;
                }
                ++right;

            }

            if (right - left == 1) {
                ++size;
                str.append(chars[left]);
            } else {
                str.append(chars[left]);
                size = size + this.intToSize(right - left, str) + 1;
            }
            for (int i = 0; i < str.toString().toCharArray().length; i++) {
                chars[i] = str.toString().charAt(i);
            }

            return size;

        }

        private int intToSize(int num, StringBuilder str) {
            String ret = String.valueOf(num);
            for (int i = 0; i < ret.length(); i++) {
                str.append(ret.charAt(i));
            }
            return ret.length();
        }


    }


//leetcode submit region end(Prohibit modification and deletion)

}
